<script setup lang="ts">
import {
  listCategories,
  addCategory,
  updateCategory,
  deleteCategories,
} from '@/api/pms/category';
import {  Picture } from '@element-plus/icons-vue';
import SingleUpload from '@/components/Upload/SingleUpload.vue';
import { onMounted, reactive, ref, toRefs, unref } from 'vue';
import { ElForm, ElMessage, ElMessageBox, ElTree } from 'element-plus';

const emit = defineEmits(['categoryClick']);

const categoryTreeRef = ref(ElTree);
const dataFormRef = ref(ElForm);

const state = reactive({
  // 遮罩层
  loading: true,
  ids: [],
  queryParam: {},
  categoryOptions: [] as Array<any>,
  formData: {
    id: undefined,
    name: undefined,
    parentId: 0,
    level: undefined,
    iconUrl: undefined,
    visible: 1,
    sort: 100,
  },
  rules: {
    parentId: [
      {
        required: true,
        message: '请选择上级分类',
        trigger: 'blur',
      },
    ],
    name: [
      {
        required: true,
        message: '请输入分类名称',
        trigger: 'blur',
      },
    ],
  },
  dialog: {
    title: '',
    visible: false,
  },
  parent: {} as any,
  current: {} as any,
});

const { loading, categoryOptions, formData, rules, dialog, parent } =
  toRefs(state);

function handleQuery() {
  state.loading = true;
  listCategories(state.queryParam).then((response) => {
    state.categoryOptions = [
      {
        id: 0,
        name: '全部分类',
        parentId: 0,
        level: 0,
        children: response.data,
      },
    ];
    state.loading = false;
  });
}

function handleNodeClick(row: any) {
  const categoryTree = unref(categoryTreeRef);
  const parentNode = categoryTree.getNode(row.parentId);

  state.parent = {
    id: parentNode.key,
    name: parentNode.label,
    level: row.level,
  };
  state.current = JSON.parse(JSON.stringify(row));
  emit('categoryClick', row);
}

function handleAdd(row: any) {
  state.dialog = {
    title: '新增商品分类',
    visible: true,
  };
  if (row.id != null) {
    // 行点击新增
    state.parent = {
      id: row.id,
      name: row.name,
      level: row.level,
    };
  }
}

function handleUpdate(row: any) {
  handleNodeClick(row);
  state.dialog = {
    title: '修改商品分类',
    visible: true,
  };
  Object.assign(state.formData, state.current);
}

function submitForm() {
  dataFormRef.value.validate((valid: any) => {
    if (valid) {
      if (state.formData.id) {
        updateCategory(state.formData.id, state.formData).then(() => {
          ElMessage.success('修改成功');
          closeDialog();
          handleQuery();
        });
      } else {
        const parentCategory = state.parent as any;
        console.log('parent', parentCategory);
        state.formData.parentId = parentCategory.id;
        state.formData.level = parentCategory.level + 1;

        addCategory(state.formData).then(() => {
          ElMessage.success('新增成功');
          closeDialog();
          handleQuery();
        });
      }
    }
  });
}

function handleDelete(row: any) {
  const ids = [row.id || state.ids].join(',');
  ElMessageBox.confirm('确认删除已选中的数据项?', '警告', {
    confirmButtonText: '确定',
    cancelButtonText: '取消',
    type: 'warning',
  }).then(() => {
    deleteCategories(ids).then(() => {
      ElMessage.success('删除成功');
      handleQuery();
    });
  });
}

function closeDialog() {
  state.dialog.visible = false;
  dataFormRef.value.resetFields();
  state.dialog.visible = false;
}

onMounted(() => {
  handleQuery();
});
</script>

<!-- 商品分类层级最多为三层，level字段标识 -->
<template>
  <div class="component-container">
    <el-tree
    class="category"
      v-loading="loading"
      ref="categoryTreeRef"
      :data="categoryOptions"
      :props="{ label: 'name', children: 'children', disabled: '' }"
      node-key="id"
      :expand-on-click-node="false"
      default-expand-all
      :accordion="true"
      @node-click="handleNodeClick"
    >
      <template #default="scope">
        <div class="category_node">
          <div>
            <el-image
              v-show="scope.data.level == 3"
              :src="scope.data.iconUrl"
              class="category_node_img"
            >
              <template #error>
                <div class="image-slot">
                  <Picture style="width: 20px; height: 20px" />
                </div>
              </template>
            </el-image>
            {{ scope.data.name }}
          </div>
          <div>
            <el-button
              v-show="scope.data.level != 3"
              type="success"
            link
              @click.stop="handleAdd(scope.data)"
            >新增</el-button>
            <el-button
              v-show="scope.data.id !== 0"
              type="warning"
            link
              @click.stop="handleUpdate(scope.data)"
            >编辑
          </el-button>
            <el-button
              v-show="
                scope.data.id &&
                (!scope.data.children || scope.data.children.length <= 0)
              "
              type="danger"
          link
              @click.stop="handleDelete(scope.data)"
            >删除</el-button>
          </div>
        </div>
      </template>
    </el-tree>

    <el-dialog :title="dialog.title" v-model="dialog.visible" width="750px">
      <el-form
        ref="dataFormRef"
        :model="formData"
        :rules="rules"
        label-width="100px"
      >
        <el-form-item label="上级分类" prop="parentId">
          <el-input v-model="parent.name" readonly />
        </el-form-item>

        <el-form-item label="分类名称" prop="name">
          <el-input v-model="formData.name" />
        </el-form-item>

        <el-form-item label="分类图标" prop="iconUrl">
          <single-upload v-model="formData.iconUrl" />
        </el-form-item>

        <el-form-item label="显示状态" prop="visible">
          <el-radio-group v-model="formData.visible">
            <el-radio :label="1">显示</el-radio>
            <el-radio :label="0">隐藏</el-radio>
          </el-radio-group>
        </el-form-item>

        <el-form-item label="排序" prop="sort">
          <el-input v-model="formData.sort"></el-input>
        </el-form-item>
      </el-form>
      <template #footer>
        <div class="dialog-footer">
          <el-button type="primary" @click="submitForm">确 定</el-button>
          <el-button @click="closeDialog">取 消</el-button>
        </div>
      </template>
    </el-dialog>
  </div>
</template>

<style lang="scss">

.category {
 &_node{
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  &_img{
    width: 20px;  height: 20px; vertical-align: middle;  margin-top: -5px;

  }
 }
}

</style>
